20132
12213
Tänään tuntien virheenkorjauksen jälkeen opin tämän säännön kovalla tavalla:
Vanhempi elementti ei koskaan pysty peittämään (pinottamaan sen päälle) alielementtiään, jos vanhemmalla on minkä tahansa arvon z-indeksi, riippumatta siitä, miten muutat lapsen CSS: ää
Kuinka voin ymmärtää tämän käyttäytymisen logiikan perusteella? Onko se teknisissä tiedoissa?
.container {
leveys: 600px;
korkeus: 600px;
taustaväri: lohi;
asema: suhteellinen;
z-indeksi: 99;
toppaus-top: 10px;
}
h1 {
taustaväri: vaaleanpunainen;
asema: suhteellinen;
z-indeksi: -1;
font-family: monospace;
}

1. Vanhempi ei voi koskaan kattaa minua, jos z-indeksini on positiivinen.

2. Silloinkin kun z-indeksini on epämiellyttävä, minua ei silti voida koskaan kattaa, jos vanhemmallani on lainkaan z-indeksiä.

Sinun on tiedettävä kaksi tärkeää asiaa: maalausjärjestys ja pinontakonteksti. Jos viitat eritelmään, löydät miten ja milloin elementit maalataan.
Pinoamiskontekstit, jotka muodostavat negatiiviset z-indeksit (lukuun ottamatta 0) sijoitetut jälkeläiset z-indeksijärjestyksessä (ensin negatiivisimmat) ja sitten puujärjestys.
Kaikki sijoitetut, peittämättömät tai muuttavat jälkeläiset puujärjestyksessä, jotka kuuluvat seuraaviin luokkiin:
Kaikki sijoitetut jälkeläiset, joiden z-indeksi: auto tai z-indeksi: 0, puujärjestyksessä.
Pinoamiskontekstit, jotka muodostavat sijoitetut jälkeläiset, joiden z-indeksit ovat suurempia tai yhtä suuria kuin 1 z-indeksijärjestyksessä (ensin pienin ensin) ja sitten puujärjestyksessä.
Tästä on selvää, että ensin maalataan elementit, joilla on negatiivinen z-indeksi vaiheessa (3), sitten se, jonka z-indeksi on yhtä suuri kuin 0 vaiheessa (8), ja lopuksi ne, joiden z-indeksi on positiivinen vaiheessa (9) , mikä on loogista. Voimme myös lukea eritelmän toisen osan:
Jokainen laatikko kuuluu yhteen pinontakontekstiin. Jokaisella tietyn pinoamiskontekstin ruudulla on kokonaislukupinotaso, joka on sen sijainti z-akselilla suhteessa muihin ruuduihin samassa pinoamiskontekstissa. Laatikot, joilla on suuremmat pinotasot, alustetaan aina laatikoiden eteen, joissa on alemmat pinotasot. Laatikoilla voi olla negatiiviset pinotasot. Laatikot, joilla on sama pinotaso pinontakontekstissa, pinotaan alhaalta ylös asiakirjopuun järjestyksen mukaan.
Myös
Paikallisen pinontakontekstin muodostava elementti luo laatikon, jolla on kaksi pinotasoa: yksi luomalle pinontakontekstille (aina 0) ja toinen pinontakontekstille, johon se kuuluu (antaa z-index-ominaisuus).
Ymmärtääksesi, milloin kukin elementti maalataan, sinun on tiedettävä sen pinontakonteksti ja pinon taso tässä pinontakontekstissa (määritelty z-indeksillä). Sinun on myös tiedettävä, muodostaako kyseinen elementti pinoamiskontekstin. Tämä on hankala osa, koska z-indeksin asettaminen tekee tämän:
Sijoitetulle ruudulle z-index-ominaisuus määrittää:
Laatikon pinotaso nykyisessä pinontakontekstissa.
Luo ruutu pinontakontekstin
Arvoilla on seuraava merkitys:

Tämä kokonaisluku on muodostetun laatikon pinotaso nykyisessä pinontakontekstissa. Laatikko luo myös uuden pinontakontekstin.
auto
Luodun laatikon pinotaso nykyisessä pinoamiskontekstissa on 0. Laatikko ei luo uutta pinontakontekstia, ellei se ole juurielementti.
Nyt meillä on kaikki tiedot kunkin tapauksen ymmärtämiseksi paremmin. Jos vanhemman elementin z-indeksiarvo on jokin muu kuin auto, se luo pinontakontekstin, jolloin lapsielementti maalataan riippumatta siitä, mikä heidän z-indeksinsä on (negatiivinen tai positiivinen). Lapsielementin z-indeksi kertoo yksinkertaisesti maalausjärjestyksen vanhemman elementin sisällä (tämä kattaa toisen pisteen).
Jos nyt vain lapsielementillä on positiivinen z-indeksi ja emme aseta mitään vanhemman elementille, maalausjärjestyksen perusteella lapsi maalataan myöhemmin (vaiheessa (9)) ja vanhempi vaiheessa (8). Ainoa looginen tapa maalata yllä oleva vanhempi on lisätä z-indeksiä, mutta tämän tekeminen saa meidät putoamaan edelliseen tapaukseen, jossa vanhempi muodostaa pinoamiskontekstin ja lapsielementti kuuluu siihen.
Ei ole mitään tapaa saada vanhempaa lapsielementin yläpuolelle, kun asetetaan lapselle positiivinen z-indeksi. Emme myöskään voi saada vanhempaa lapsen yläpuolelle, jos asetamme z-indeksin vanhemmalle elementille, joka poikkeaa autosta (joko positiivinen tai negatiivinen) .1
Ainoa tapaus, jossa voimme saada lapsen vanhempiensa alapuolelle, on asettaa negatiivinen z-indeksi lapsielementille ja pitää vanhempi z-indeksissä: auto, joten tämä ei luo pinoamiskontekstia ja seuraa maalausjärjestystä lapsi maalataan ensin.
Z-indeksin lisäksi on muitakin ominaisuuksia, jotka luovat pinoamiskontekstin. Jos kohtaat odotetun pinoamisjärjestyksen, sinun on otettava huomioon myös nämä ominaisuudet, jotta näet, onko pinontakonteksti luotu.
Joitakin tärkeitä seikkoja, jotka voimme päätellä yllä olevista:
Pinoamiskontekstit voivat sisältyä muihin pinoamisympäristöihin, ja ne yhdessä luovat pinoamisyhteyksien hierarkian.
Jokainen pinontakonteksti on täysin riippumaton sisaruksistaan: pinoamista käsiteltäessä otetaan huomioon vain jälkeläiset.
Jokainen pinontakonteksti on itsenäinen: kun elementin sisältö on pinottu, koko elementti otetaan huomioon päällekkäisen pinontakontekstin pinoamisjärjestyksessä. viite
1: on joitain hakkeroivia tapoja, jos harkitsemme 3D-muunnoksen käyttöä.
Esimerkki elementistä, joka menee sen pääelementin alle, vaikka tällä olisi määritetty z-indeksi.
.box {
asema: suhteellinen;
z-indeksi: 0;
korkeus: 80px;
tausta: sininen;
muunnostyyli: säilytä-3d; /* Tämä on tärkeää */
}
.box> div {
marginaali: 0 50px;
korkeus: 100px;
tausta: punainen;
z-indeksi: -1; / * tämä ei tee mitään * /
muunnos: käännä Z (-1px); / * tämä tekee taikaa* /
}
Toinen esimerkki, jossa voimme sijoittaa elementin kahden elementin väliin toiseen pinoamiskontekstiin: .box { asema: suhteellinen; z-indeksi: 0; korkeus: 80px; tausta: sininen; } .box> div { marginaali: 0 50px; korkeus: 100px; tausta: punainen; z-indeksi: 5; muunnos: käännä Z (2px); } .outside { korkeus: 50px; tausta: vihreä; marginaali: -10px 40px; muunnos: käännä Z (1px); } runko { muunnostyyli: säilytä-3d; }
Meillä voi olla myös hullu pinoamisjärjestys, kuten alla: .box { leveys: 100px; korkeus: 100px; sijainti: absoluuttinen; } runko { muunnostyyli: säilytä-3d; }
Meidän on huomattava, että tällaisen hakkeroinnin käyttämisellä voi olla joitain sivuvaikutuksia johtuen siitä, että muunnostyyli, perspektiivi ja muunnos vaikuttavat sijaintiin: absoluuttinen / kiinteä elementti. Aiheeseen liittyvä: CSS-suodatin vanhemmalta rikkoo lapsen sijainnin 10 | Hyvä tapa ajatella tätä on, että jokainen vanhempi sisältää oman pinontakontekstin. Sisaruselementit jakavat vanhemman pinoamisjärjestyksen ja voivat siksi olla päällekkäisiä. Lapsielementti saa AINA pinoamiskontekstin vanhemmansa perusteella. Tästä syystä negatiivisen z-indeksiarvon tarve työntää lapsi "takana" vanhemman (0) pinontakontekstin. Ainoa tapa poistaa elementti vanhemman kontekstista on position: fix-käyttö, koska se pakottaa sen käyttämään ikkunaa kontekstiin. 1 | Mozillan dokumentaatiossa sanotaan Z-indeksin CSS-ominaisuus asettaa sijoitetun elementin ja sen jälkeläisten tai joustavien kohteiden z-järjestyksen. Tässä on muutama lisälogiikka toisesta StackOverflow-artikkelista, joka koskee lapsia ja jälkeläisiä. 2 | Kuinka voin ymmärtää tämän käyttäytymisen logiikan perusteella? Minulle on vaikea ymmärtää ongelmaa logiikan perusteella. Vanhempi sisältää lapsensa. Kulho voidaan peittää toisella kulholla. Mutta et voi peittää keittoa kulholla, ellet laita keittoa kulhosta. z-Index asettaa päällekkäisten elementtien järjestyksen. Vanhempi ei voi olla päällekkäinen lapsensa kanssa. ImhO, se on täysin loogista. | Vastauksesi StackExchange.ifUsing ("editor", function () { StackExchange.using ("externalEditor", function () { StackExchange.using ("katkelmat", function () { StackExchange.snippets.init (); }); }); }, "koodinpätkät"); StackExchange.ready (function () { var channelOptions = { tunnisteet: "" .split (""), id: "1" }; initTagRenderer ("". split (""), "" .split (""), channelOptions); StackExchange.using ("externalEditor", function () { // Sinun on käynnistettävä editori katkelmien jälkeen, jos katkelmat ovat käytössä if (StackExchange.settings.snippets.snippetsEnabled) { StackExchange.using ("katkelmat", function () { createEditor (); }); } muu { createEditor (); } }); funktio createEditor () { StackExchange.prepareEditor ({ useStacksEditor: väärä, heartbeatType: 'vastaus', autoActivateHeartbeat: epätosi, convertImagesToLinks: true, noModals: totta, showLowRepImageUploadWarning: tosi, maineToPostImages: 10, bindNavPrevention: tosi, postfix: "", imageUploader: { brandingHtml: "Palvelun tarjoaa \ u003ca href = \" https: //imgur.com/ \ "\ u003e \ u003csvg class = \" svg-icon \ "width = \" 50 \ "height = \" 18 \ "viewBox = \ "0 0 50 18 \" fill = \ "none \" xmlns = \ "http: //www.w3.org/2000/svg \" \ u003e \ u003cpath d = \ "M46.1709 9.17788C46.1709 8.26454 46.2665 7.94324 47.1084 7.58816C47.4091 7.46349 47.7169 7.36433 48.0099 7.26993C48.9099 6.97997 49.672 6.73443 49.672 5.93063C49.672 5.22043 48.9832 4.61182 48.1414 4.61182C47.4335 4.61182 46.7256 4.7506 4.916 43.1481 6.59048V11.9512C43.1481 13.2535 43.6264 13.8962 44.6595 13.8962C45.6924 13.8962 46.1709 13.2535 46.1709 11.9512V9.17788Z \ "/ \ u003e \ u003cpath d = \" M32.492 14.44.44 14.44 144 144 144 144 044 144 044 144 044 144 044 144 044 144 044 144 044 144 044 144 044 144 0 144 144 144 144 144 144 144 144 144 144 144 144 144 144 144 144 144 144 144 144 144 144 144 144 144 144 141 141 144 14 14 14 14 14 14 14 14 14 14 41.5985 12.6954 41.5985 10.1419V6.59049C41.5985 5.28821 41.1394 4.66232 40.1061 4.66232C39.0732 4.66232 38.5948 5.28821 38.5948 6.59049V9.60062C38.5948 10.8521 38.2696 11.5455 37.0451 11.5455C35 521 35.4954 9.60062V6.59049C35.4954 5.28821 35.0173 4.66232 34.0034 4.66232C32.9703 4.66232 32.492 5.28821 32.492 6.59049V10.1419Z \ "/ \ u003e \ u003cpath fill-rule = \" evenodd \ "clip-rule = = \ "M25.6622 17.6335C27.8049 17.6335 29.3739 16.9402 30.2537 15.6379C30.8468 14.7755 30.9615 13.5579 30.9615 11.9512V6.59049C30.9615 5.28821 30.4833 4.66231 29.4502 4.66231C28.9950 4 419 4 269 4 269 4 269 4 4 492 4 4 492 4 4 492 4 4 492 435 4 435 4 432 435 4 435 4 435 4 432 435 4 432 435 4 432 435 4 432 435 4 439 435 4 432 4 9 495 .1369 4.56087 21.0134 6.57349 21.0134 9.27932C21.0134 11.9852 23.003 13.913 25.3754 13.913C26.5612 13.913 27.4607 13.4902 28.1109 12.6616C28.1109 12.7229 28.1161 12.779928,121 12.8346C28.1256 12,8854 28,1301 12,9342 28,1301 12.983C28.1301 14,4373 27,2502 15,2321 25,777 15.2321C24.8349 15,2321 24,1352 14,9821 23,5661 14.7787C23.176 14,6393 22,8472 14,5218 22,5437 14.5218C21.7977 14,5218 21,2429 15,0123 21,2429 15.6887C21.2429 16,7375 22,9072 17,6335 25,6622 17,6335 ZM24.1317 9.27932C24.1317 7.94324 24.9928 7.09766 26.1024 7.09766C27.2119 7.09766 28.0918 7.94324 28.0918 9.27932C28.0918 10.6321 27.2311 11.5116 26.1024 11.5116C24.9737 11.5116 24.1317 \ 913 \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u003d \ u00e4 /. 8045 11.9512C16.8045 13.2535 17.2637 13.8962 18.2965 13.8962C19.3298 13.8962 19.8079 13.2535 19.8079 11.9512V8.12928C19.8079 5.82936 18.4879 4.62866 16.4027 4.62866C15.1594 4.62866 14.279 4.98375 133 433 7.9466 5.5079C7.58314 4.9328 7.10506 4.66232 6.51203 4.66232C5.47873 4.66232 5.00066 5.28821 5.00066 6.59049V11.9512C5.00066 13.2535 5.47873 13.8962 6.51203 13.8962C7.54479 13,8962 8,0232 13,2535 8,0232 11.9512V8.90741C8.0232 7,58817 8,44431 6,91179 9,53458 6.91179C10.5104 6,91179 10,893 7,58817 10,893 8.94108V11.9512C10.893 13,2535 11,3711 13,8962 12,4044 13.8962C13.4375 13,8962 13,9157 13,2535 13,9157 11.9512V8.90741C13.9157 7,58817 14,3365 6,91179 15,4269 6.91179C16.4027 6.91179 16.8045 7.58817 16.8045 8.94108V11.9512Z \ "/ \ u003e \ u003cpath d = \" M3.31675 6.59049C3.31675 5.28821 2.83866 4.66232 1.82471 4.66232C0.791758 4.66232 0.3323535 5.23235 0.3323535 5.235 13,8962 1,82471 13,8962C2,85798 13,8962 3,31675 13,2535 3,31675 11,9512V6,59049Z \ "/ \ u003e \ u003path d = \" M1.87209 0.400291C0.843612 0.400291 0 1.1159 0 1.98861C0 2.87867 3.576769 467 1.98861C3.7234 1.1159 2.90056 0.400291 1.87209 0.400291Z \ "fill = \" # 1BB76E \ "/ \ u003e \ u003c / svg \ u003e \ u003c / a \ u003e", contentPolicyHtml: "Käyttäjän käyttöoikeudet lisensoitu \ u003ca href = \" https: //stackoverflow.com/help/licensing \ "\ u003ecc by-sa \ u003c / a \ u003e \ u003ca href = \" https://stackoverflow.com / legal / content-policy \ "\ u003e (sisältökäytäntö) \ u003c / a \ u003e", allowUrls: totta }, onDemand: totta, discardSelector: ".discard-answer" , välittömästiShowMarkdownHelp: true, enableTables: true, enableSnippets: true }); } }); Kiitos vastauksestasi pinon ylivuotoon! Muista vastata kysymykseen. Anna yksityiskohdat ja jaa tutkimuksesi! Mutta vältä… Pyydä apua, selvennystä tai vastaamista muihin vastauksiin. Lausuntojen tekeminen mielipiteen perusteella; varmuuskopioi ne viitteillä tai henkilökohtaisella kokemuksella. Jos haluat lisätietoja, katso vinkit hyvien vastausten kirjoittamiseen. Luonnos tallennettu Luonnos hylätty Rekisteröidy tai kirjaudu sisään StackExchange.ready (function () { StackExchange.helpers.onClickDraftSave ('# login-link'); }); Rekisteröidy Googleen Rekisteröidy Facebookilla Rekisteröidy sähköpostilla ja salasanalla Lähetä Lähetä vieras Nimi Sähköposti Pakollinen, mutta ei koskaan näytetty StackExchange.ready ( funktio () { StackExchange.openid.initPostLogin ('. New-post-login', 'https% 3a% 2f% 2fstackoverflow.com% 2fquestions% 2f54897916% 2fwhy-cant-an-element-with-az-index-value-cover-its- lapsi% 23uusi vastaus ',' kysymyssivu '); } ); Lähetä vieras Nimi Sähköposti Pakollinen, mutta ei koskaan näytetty Lähetä vastauksesi Hylkää Klikkaamalla "Lähetä vastauksesi" hyväksyt käyttöehdot, tietosuojakäytännön ja evästekäytännön Eikö vastausta etsit? Selaa muita kysymyksiä, joihin on merkitty css css-position z-index tai kysy oma kysymyksesi.